nbgrader late penalty tutorial

This module process the nbgrader generated csv grades files and the output directories, and use canvas api to post grade to students, with late penalty and the messages.

How to use

from LatePenalty.nbgrader import nbgrader_grade

source

nbgrader_grade

 nbgrader_grade (credentials_fp='', late_exception_fp='',
                 API_URL='https://canvas.ucsd.edu', course_id='',
                 assignment_id=-1, grades_fp='', verbosity=0)

Initialize Canvas Group within a Group Set and its appropriate memberships

Type Default Details
credentials_fp str credential file path. Template of the credentials.json
late_exception_fp str late exception yaml file path. Template of the late_exception.yaml
API_URL str https://canvas.ucsd.edu the domain name of canvas
course_id str Course ID, can be found in the course url
assignment_id int -1 assignment id, can be found in the canvas assignment url
grades_fp str nbgrader csv grades exports file path
verbosity int 0 Controls the verbosity: 0 = Silent, 1 = print all messages
grade = nbgrader_grade("../../../credentials.json",
                       late_exception_fp="../data/late_exception_nbgrader.yaml",
                       course_id=45023,
                       assignment_id=638121,
                       grades_fp="../data/grades_example.csv",
                       verbosity=1,
                      )
Authorization Successful!
Course Set:  COGS 108 - Data Science in Practice - Fleischer [SP23] 
Getting List of Users... This might take a while...
Users Fetch Complete! The course has 446 users.
Assignment D1 Link!
# take a look at nbgrader csv file
grade.grades.head()
assignment duedate timestamp student_id last_name first_name email raw_score late_submission_penalty score max_score
0 D1_COGS108_Sp23 2023-04-15 07:59:00 2023-04-11 00:32:28.990983 student_0 NaN NaN NaN 2.0 0.0 2.0 2.0
1 D1_COGS108_Sp23 2023-04-15 07:59:00 2023-04-17 03:59:02.156619 student_1 NaN NaN NaN 2.0 0.0 2.0 2.0
2 D1_COGS108_Sp23 2023-04-15 07:59:00 2023-04-13 02:03:02.382628 student_2 NaN NaN NaN 2.0 0.0 2.0 2.0
3 D1_COGS108_Sp23 2023-04-15 07:59:00 2023-04-14 01:23:48.922147 student_3 NaN NaN NaN 2.0 0.0 2.0 2.0
4 D1_COGS108_Sp23 2023-04-15 07:59:00 2023-04-12 00:45:49.963719 student_4 NaN NaN NaN 2.0 0.0 2.0 2.0

Late Submission Exception

with open("../data/late_exception.yaml", "r") as f:
    print(f.read())
student_1:
    allowed_late_days: 7
    reasons: sickness

student_3:
    allowed_late_days: 10
    reasons: family issue
grade.late_exception
{'student_1': {'allowed_late_days': 7, 'reasons': 'sickness'},
 'student_3': {'allowed_late_days': 10, 'reasons': 'family issue'}}

Post Grades

As we can see, the reamining slip day for student 1 and student 3 is 7 and 10 respectively.


source

nbgrader_grade.post_to_canvas

 nbgrader_grade.post_to_canvas (target_assignment:str,
                                passed_assignments:List[str],
                                student=None, A1_git=False, quarter='',
                                default_credit:int=7,
                                late_submission_deadline:int=5, post=True,
                                force=False)

Post grade to canvas with late penalty.

Type Default Details
target_assignment str target assignment name to grab the late time. Must in the column of nbgrader assignment csv
passed_assignments List list of passed assignment. Must in the column of nbgrader assignment csv
student NoneType None if specify, only grade that student.
A1_git bool False Set True if grading A1 for COGS108
quarter str Set the quarter, for example, Fa23, Wi24, etc.
default_credit int 7 default amount of late days calculated, used in FA24 COGS108
late_submission_deadline int 5 the maximum amount of late days that we allow. Implements: We don’t accept late submission after 5 days.
post bool True for testing purposes. Can halt the post operation
force bool False whether force post grade. If False, will not post the same grade again, if True, will post the grade again.

Post grade of assignment D1_COGS108_Sp23

grade.post_to_canvas("D1_COGS108_Sp23", [], False)
Post Disabled
The message for student_0 is: 
D1_COGS108_Sp23: 
Submitted intime
Remaining Slip Credit: 5 Days

Post Disabled
The message for student_1 is: 
D1_COGS108_Sp23: 
Late Submission: 2 Days Late
Slip Credit Used. No late penalty applied
Remaining Slip Credit: 5 Days

Post Disabled
The message for student_2 is: 
D1_COGS108_Sp23: 
Submitted intime
Remaining Slip Credit: 5 Days

Post Disabled
The message for student_3 is: 
D1_COGS108_Sp23: 
Submitted intime
Remaining Slip Credit: 10 Days

Post Disabled
The message for student_4 is: 
D1_COGS108_Sp23: 
Submitted intime
Remaining Slip Credit: 5 Days

Post grade of assignment A1_COGS108_Sp23. Before you post it, you will have to link the canvas assignment to A1 with the following command.


source